草庐IT

http - 限制从 HTTP 响应中读取的字节数

全部标签

ruby - stub http 请求以返回带有 Net::HTTPResponse 的 HTTPartyResponse

我正在尝试编写一个rspec规范来测试我的逻辑是否能够处理状态代码为401的特定Net::HTTPResponse。当我使用HTTParty时,.get将返回一个HTTPartyResponse并且我'我们将使用httparty_repsonse_object.response检索Net::HTTPResponse。net_response_object=Net::HTTPResponse.new(1.1,401,'Forbidden')#notsurewhattodohere?writeatestdoubletoreturnanet_response_object?stub_requ

ruby - 如何限制 block 被调用的次数?

在HowdoIlimitthenumberofreplacementswhenusinggsub?,有人建议用下面的方法来做有限数量的替换:str='aaaaaaaaaa'count=5pstr.gsub(/a/){ifcount.zero?then$&elsecount-=1;'x'end}#=>"xxxxxaaaaa"它有效,但代码混淆了替换(5)的次数和应该替换的内容(如果应该替换,则为“x”,否则为$&)。是否可以将两者分开?(如果在这种情况下很难将这两件事分开,但在其他一些情况下可以做到,请将其作为答案发布) 最佳答案 将

ruby - 为什么在 Net::HTTP 上使用 Faraday?

为什么有人会使用Faradaygem而不是直接使用Net::HTTP?使用这样的包装器有什么好处? 最佳答案 直接使用Net::HTTP适配器就可以了,它只是将您的代码绑定(bind)到一个特定的接口(interface),这可能与其他工具不同。人们会使用Faraday的主要原因是它包装了多个适配器,其中之一是Net::HTTP。如果您使用Faraday并开始使用Net:HTTP,您可以稍后决定使用Excon,Typhoeus,Patron或EventMachine无需更改超过一两行配置。如果您直接使用Net::HTTP,则必须更改

ruby - Net::HTTP 中的服务器名称指示支持?

我正在尝试让Ruby的Net::HTTP实现与SNI一起工作。mail.google.com和gmail.com都位于同一个IP地址上,因此当通过SSL连接时,Google服务器需要知道要使用哪个证书。默认情况下,它会返回mail.google.com证书,如果您尝试实现WebFinger,这就是一个问题。WebFinger要求您检索https://gmail.com/.well-known/host-meta以获取LRDD信息,但是,出于安全原因,验证SSL证书至关重要信息。由于Google在这种情况下提供默认的mail.google.com证书,因此SSLpost_connecti

ruby-on-rails - 限制每个用户的请求数量(使用机架攻击和设计)

我正在使用https://github.com/kickstarter/rack-attack/#throttles限制对某些网址的请求。机架攻击文档展示了如何通过请求IP或请求参数进行限制,但我想做的是限制每个用户的请求。因此,无论IP是什么,用户都应该能够在特定时间范围内发出不超过n个请求。我们使用devise进行身份验证,我想不出一种简单的方法来根据请求唯一标识用户。我应该在session/cookie中存储用户ID吗?也许是一个uniq哈希?您对实现这一目标的最佳方式有何看法? 最佳答案 想通了。Devise已将用户ID存储

ruby - 如何在 Node.js/RoR 中监控 20 个网站(Ping 或 HTTP)的正常运行时间

每5分钟(例如)ping20个网站的列表以了解该网站是否响应HTTP202的最佳方法是什么?最简单的想法是将20个URLS保存在数据库中,然后运行数据库并对每个URL执行ping操作。但是,当一个人不回答时会发生什么?之后的人会怎样?此外,是否有更好但更简单的解决方案?恐怕该列表会增长到20000个网站,然后没有足够的时间在我需要ping的5分钟内全部ping通它们。基本上,我是在描述PingDom、UptimeRobot等的工作原理。我正在使用node.js和RubyonRails构建这个系统。我也倾向于使用MongoDB来保存所有ping和监控结果的历史记录。建议?非常感谢!

ruby-on-rails - 使用 cookie 制作 Ruby Net::HTTP::Get 请求

我想通过ruby​​打开我的stackoverflow.com页面。我希望看到它就像我通过了身份验证一样。我从GoogleChrome中获取了usrcookie并创建了以下代码段:require'net/http'require'cgi'url="http://stackoverflow.com/users/1650525/alex-smolov"uri=URI(url)http=Net::HTTP.new(uri.host,80)request=Net::HTTP::Get.new(uri.request_uri)cookie=CGI::Cookie.new("usr","[myco

ruby - 相同的字符串但不同的字节码

我有两个字符串:a='hànội'b='hànội'当我将它们与a==b进行比较时,它返回false。我检查了字节码:a.bytes=[104,97,204,128,32,110,195,180,204,163,105]b.bytes=[104,195,160,32,110,225,187,153,105]这是什么原因?我该如何修复它以便a==b返回true? 最佳答案 这是Unicodeequivalence的问题.为了比较这些字符串,您需要对它们进行规范化,以便它们都对这些类型的字符使用相同的字节序列。a.unicode_n

ruby-on-rails - RoR Net::HTTP 发布错误未定义方法 `bytesize'

我目前正在反复用头撞墙,直到通过这个问题。我正在使用ruby​​-1.9.3-p194和Rails。我正在尝试发出一个post请求,我可以使用Net::HTTP.post_form完成它,但我不能在这里使用它,因为我需要在header中设置一个cookie。http.post是错误的说法"undefinedmethod`bytesize'for#"因为我猜它正在尝试对发送的数据执行一些操作。有没有人有某种修​​复或解决方法?谢谢headers={'Cookie'=>'mycookieinformationinhere'}uri=URI.parse("http://asite.com/w

ruby-on-rails - Rails 3.1 限制用户创建的对象

我想限制用户可以创建的模型对象的数量。我已经尝试了以下但它不起作用。我知道rails3.1中发生了一些变化,但不确定现在如何完成。classUser5,:dependent=>:destroy#Thisdoesn'tworkendclassThings 最佳答案 尝试这样的事情:classUser:createdefthing_count_within_limitifself.user.things(:reload).count>=5errors.add(:base,"Exceededthinglimit")endendend编辑: